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1 . INTRODUCTION 

The DTC-10-1 Host Adapter is a single board interface card for the IEEE 
696.1 S-100 Bus. This host adapter may be utilized with any of the Data 
Technology Corporation 1KA Series Disk Drive Controllers. This 
specification provides the programming mechanism and command block 
format utilized by the DTC-10-1 Host Adapter. The detailed 
specifications for the DTC controllers can be found in the respective" 
controller documentation. 

The DTC-10-1 Host Adapter fits into a single S-100 Bus slot and 
presents one unit load to the bus. 

Commands are issued to the controller through the Host Adapter in the 
host computer. The controller accepts data from the Host Adapter and 
transfers the data to the correct location on the disk. In addition, 
the controller will detect/correct burst errors from the fixed disk 
drive (4 bits in length) before data is transferred to the host 
computer (on hard disk and non-IBM format floppies only) . 

1.1 Sample Disk Subsystems 

The DTC-10-1 Host Adapter will operate with any DTC controller with the 
standard DTC-1KA host interface. All of the DTC-1KA controllers have 
the identical host bus protocol, so that software developed for one 
controller can be easily modified for use with other DTC-1KA 
controllers. Each of the DTC controllers complies with the interface 
reguirements for the particular disk drive; installation is therefore 
fairly simple. 

A list of available DTC-1KA controllers and their respective disk 
drives follows. Because new, and sometimes plug-compatible, drives are 
constantly being introduced this list is only representative. 



CONTROLLER 



DISK AND CAPACITY 



DTC 510 

DTC 520 
SA1410 



Seagate Technogy ST506 or eguivalent 

(Olivetti, RMS, and Tandon Magnetics) 

1 or ? ST506 drives; 3 or 6M-bytes each 

ST506 (1 to 2) and mini-floppy (1 to 3) 

Shugart Associates SA600 
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SA1420 
SA1401 
SA1403 
SA1403D 

SA1404 
SA1404D 

SA1406 

SA1407 
DTC101 

DTC101D 

DTC900/910 

DTC600/610 



Shugart Associates SA600 with 96 TPI ; mini-floppy 

2 Shugart Associates SA1000 (5 or lOM-bytes) 

4 SAlOO's with non-IBM (ECC format) floppies 

SA1000 with integral IBM-compatible 
single/double-density 8-inch flexible disk 
drive backup 

Shugart Associates SA4000 (14 to 58M-bytes) 

SA4000 with SA800/850 integral IBM-compatible 
single/double-density flexible disk drive backup 

SA1000 with Data Electronics Streaker streaming 
tape backup (10 to 20M-bytes) 

SA4000 with DEI Streaker backup 

Memorex 101 (11 to 2 2M-bytes) 
Fujitsu 2301/2 (11 to 22M-bytes) 

Memorex 101, Fujitsu 2301/2 and integral 
IBM single/double-density backup 

Data Peripherals DP100 (10M-bytes^ 8-inch 
hard disk cartridge with SA1000 fixed disk 

CDC Finch (24M-bytes^ with optional IBM 
single/double-density floppy backup 



2.0 DTC-10-1 BASIC FEATURES 

The DTC-10-1 has a full set of features that enable it to be an 
integral part of an S-100 system. Included in the circuitry are: 

* Processor I/O and/or DMA data transfer logic 

* DMA capable of operation to 300K-bytes/sec 

* Interrupt or tie-in to off-board vectored interrupt generator 

* Phantom Boot capability 

* 6 Mhz operation 
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2 . 1 Theory of Operation 

Upon Reset the Phantom EPROM is enabled (removing a jumper can disable 
this function) . The EPROM looks like a repeating sequence of 512 Bytes 
from address to FFFFFF. The board will pull the Phantom line (67) 
only when a sMEMR cycle is initiated. Therefore, the CPU can read the 
boot program, tranfer it to regular memory, jump to it and disable the 
Phantom circuit, and then load a CP/M boot program from disk. 

Disk commands are issued to the DTC controller via commands stored in 
the main memory (the command structure is described in section 4.0 of 
each of the DTC controller specifications) . Depending on the type of 
command, the controller will request up to 10 command bytes. Upon 
receipt of the last command byte, the controller will begin execution 
of the command . 

For the data transfer commands, a check is performed on the disk 
address and status is flagged if it exceeds the drive limits. The data 
is stored in a 1 sector buffer on the controller before it is transferred 
to the host or disk drive. This buffer eliminates any possibility of 
data overruns between the host and the disk. 

Upon completion of the command, the controller will output the 
completion status to the data register in the host adapter. (Further 
delineation of the completion status may be requested by issuing the 
appropriate sense commands) . 

2.2 1KA Host Interface 

The electrical interface to the DTC disk drive controllers are all 
based on a common bus structure. The DTC-10-1 will work with any of 
these hard disk controllers as outlined in section 1.1 and Appendix B. 

2.3 IEEE 696.1 Bus Interface 

The DTC-10-1 Host Adapter is designed to operate in S-100 systems based 
upon the IEEE standard 696.1. It features 16-bit I/O addressing, 24-bit 
memory addressing and 8-bit data paths. The DMA arbitration operates 
according to the scheme described in the IEEE 696.1 publication. The 
IEEE 696 standard pin description is outlined in Appendix C. 
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3.0 DTC-10-1 HARDWARE AND OPERATION 

3.1 Interface Register Definition 

The interface registers for the DTC-10-1 Host Adapter are listed below. 
B represents the 6 most significant bits of the I/O address (or the 14 
most significant bits in a 16-bit I/O address.) 

HEX Address Register 

b0 Data in /out Register DAR 

bl Control Register (write only) CNR 

bl Completion Status Register (read) CSTAT 

b2 Status Register (read only) BSTAT 

b2 Clear DMA Address (write pulse) CLRDMA 

b3 DMA Address (write only) DMADD 

b3 Clear Phantom Status (read pulse) CLRPHANT 

3.1.1 Register Definition 

DATA INPUT REGISTER - Disk read data, completion status, and controller 
sense bytes are passed through this register. The data is held for each 
handshake cycle. 

DATA OUPUT REGISTER - Command bytes and disk data are passed through 
this register to the controller. Data is latched and held until updated 
by the host. 

CONTROL REGISTER - Provides control over the controller select process 
and host adapter operations. 

COMPLETION STATUS REGISTER - Stores the controller completion status 
during both DMA and non-DMA command cycles. 

STATUS REGISTER - Enables the host to read the status of the host bus 
and monitor the host adapter opertation. 

CLEAR DMA ADDRESS - A write to this port produces a pulse that resets 
the internal DMA address counter to zero 

CLEAR PHANTOM STATUS - A read to this port disables the on board 
Phantom boot PROM, so the host can resume normal operation. 

DMA ADDRESS REGISTER - DMA address bytes are sent to this register in 
the following order: Byte address 16 to 23, 8 to 15, to 7. If only 
16-bit addresses are used in the host computer, two bytes must be sent. 
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3.1.2 Bit Definition For Unique Registers 
Control Register (CNR) Output Address MN1 



Bit 


7 


Bit 


6 


Bit 


5 


Bit 


4 



I 



Bit 3 

Bit 2 
Bit 1 
Bit 



Not used 

Assert select and Data bit - 

used to access a controller. 
Not used 
Interrupt Enable - enables the interrupt 

channel, must be set prior to Bit 3. 
Request Interrupt Enable - the interrupt 

will activate if REQ is present. 
Not used 

Enable data, after the selection process. 
DMA Enable - the DMA channel will activate 

when REQ and DATA are present. 



BUS STATUS - processor can read status of host bus 
Bus Status (BSTAT) Input Address MN3 



Bit 7 

Bit 6 

Bit 5 
Bit 4 
Bit 3 
Bit 2 

Bit 1 
Bit 



REQ - indicates the controller either 

requests data or has data for the host 

adapter. 
IN/OUT* (reference to controller) - low 

indicates data to host adapter, high 

indicates data to controller. 
MSG - indicates last byte in data or 

command string. 
COM/DTA* - a command to the controller will 

have a high, data will be low. 
BUSY - indicates the status of the busy 

signal; high means controller is busy. 
PERR - received parity error. This bit 

set indicates that the data from the 

controller had a parity error. This bit 

is reset by outputtng a COMMAND (bOl) 
LINT - Interrupt has been activated. 

This bit is reset by reading BSTAT. 
DONE - this bit is set when the DMA is not 

enabled or if a DMA has completed. It is 

reset when the DMA is enabled. 
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3.2 Normal Command Sequence Operation 

The method by which a command is executed is as follows: 

1 - Device driver builds a Command Descriptor Block (CDB) in 

system memory (see section 4.0 of the appropriate 
DTC controller specification) . 

2 - The driver then writes the address of the first byte of 

the CDB into the Command I/O Pointer Block (CIOPB) of the 
command driver routine. 

3 - The DATA ADDRESS (DAD) is also set up if a data transfer is 

required. Commands requiring data transfers are READ, WRITE, 
READ ID, REQUEST SENSE, REQUEST SYNDROME, and WRITE ECC. 
If the DMA channel is to be used, the DAD is written into 
the DMADD register in the following order: most significant 
byte, middle byte and least significant byte. 

4 - The driver now performs a GETCON routine which determines 

if the controller is busy. When it is not busy, the GETCON 
routine will assert the SELECT line until the controller 
responds with a BUSY. 

5 - When the controller responds to the host adapter by 

asserting BUSY, the driver shifts to the OUTCOM routine. 
In response to the REQuest bit in the BSTAT, the driver 
passes the command one byte at a time to the controller. 

6 - The controller verifies that the command is correct and 

begins the command execution phase. At this time the 

data is transferred to or from the host adapter and into 

or out of the S-100 memory. If the DMA is activated, the rest 

of the command cycle will proceed automatically. 

7 - After the data transfer is completed, the controller 

enters the command completion phase. The controller 
sends a one-byte completion status to the host adapter 
indicating whether or not an error occurred during command 
execution. This is handled by the CMPSTAT routine in the 
programmed I/O mode or automat icaly in the DMA mode. 
Finally, the controller sends the message byte (of zeroes), 
and the operation is complete. The DONE bit will be set if 
in DMA mode. 

8 - At this time the controller enters the idle (non-BUSY) mode 

awaiting another command. If an error was encountered by the 
controller, the CMSTAT routine will return with it in the C 
register. It is the responsibility of the device driver to 
issue a REQUEST SENSE command to request any detailed 
information about the error. 
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3.3 Hardward Theory Of Operation 

The DTC-10-1 Host Adapter serves as a data channel for the controller. 
Commands and data are fetched /stored to the system memory as a function 
of REQ. The host adapter consists of Command and Status Registers, a 
DMA channel, and an interrupt latch. The registers are addressed as I/O 
ports. Commands and data are passed through these registers as a 
function of the I/O driver routine and the controller status lines. 
The host adapter will return an ACK after each DATA or COMMAND cycle 
has been completed. 

Each memory cycle is initiated when the controller asserts REQ. The 
driver will respond by reading/writing the data register. 

When data is transferred to the host adapter, the data on the host bus 
is held until the memory write is completed. When data is transferred 
to the controller, the data is latched into a holding register, then 
sent to the controller. 

3.3.1 I/O Logic Operation (Bus Slave) 

The host adapter responds to commands from the CPU processor to either 
read a particular register or write to a register. The 14-bit address 
selection (4 I/O locations = 2 Bits) is set with the dipswitches at 
location 12D (Address bits 15 to R) and 7D (Address bits 7 to 2 ) . The 
dipswitch selects a block of four I/O addresses. A read is selected 
when lines DBIN, PR/W* , and SINP are asserted with the appropriate I/O 
address. A write is performed when SOUT is high and PR/W* is low along 
with the I/O address. Because low power Schottky logic is used, the I/O 
logic will perform at the highest speed clocks now currently in use. 

3.3.2 I/O Logic DMA Channel 



The DMA channel is activated when the DMA enable bit is set and REQ and 
DATA are passed from the controller. The DMA begins the IEEE 696 
arbitration process by pulling down the HOLD line and asserting the DMA 
arbitratrion bits DMAO* through DMA3*. The DMA priority is set by the 8- 
pin DIP switch below 4B. When the the CPU responds with HOLDA the 
arbitration process is complete. If the arbitration is unsuccessful for 
the DTC-10-1 it will try again as soon as HOLDA goes low. After a 
successful arbitration, the DMA will begin transferring data under the 
command of the controller. Once the host adapter has the bus the entire 
data move can proceed without dropping the bus, or the host adapter can 
be set to drop the bus after each cycle. This function is set by a 
jumper at location TP2 (near 3B) . It is recommended that dynamic 
memories be self-refreshing as a Z-80 based refresh will be inhibited 
by the DMA cycle. The DMA logic will respond to a memory that is not 
ready (pREADY or XREADY) by stretching the read and/or write pulses. If 
the controller asserts IN, then the DMA will read data from memory. If 
IN is deasserted, then the DMA will write to memory. When COMMAND is 
asserted the DMA will drop the bus and input the completion status to 
the CSTAT register. Upon receipt of the MSG bit, the DONE bit will be 
set. If the Interrupt enable is set, the MSG bit will cause an 
interrupt. 
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3.3.3 Interrupt Logic 

will activate when and if I wn <« ? port) . The interrupt 
read operation wh^n 32 co^anfstrinris'pa^sS't C ?£ ** USed in a 
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4.0 ELECTRICAL/MECHANICAL SPECIFICATIONS 

HOST ADAPTER PHYSICAL PARAMETERS 
(The DTC-10-1 Host Adapter fits into a single S-100 slot) 
Width 
Length 
Height 
Weight 



10.0 inches 

5.125 inches 

0.75 inch 

0.7 lbs. 



Temperature 
(degrees F/O 



Relative Humidity 
((a 40 degrees F, 
wet bulb temp, 
no condensation) 

Altitude 



ENVIRONMENTAL PARAMETERS 
Operating : 
32/0 to 131/55 
10% to 95% 



Storage: 
-40/-10 to 167/75 
10% to 95% 



sea level to 
10K feet 



POWER REQUIREMENTS 



sea level to 
15K feet 



Voltage <a current(host adapter) +8 VDC @ 1.5A(max) 



Note: For the physical parameters of the controller, refer to its DTC 
controller specification. 
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| I 5.0 INSTALLATION 
5.1 Inspection 

Inspect all shipping containers for damage. If a container is damaged, 
the contents shSuld be checked and the DTC-10-1 Host Adapter verified 
electrically. If the host adapter is damaged, call Data Technology 
Corporation Customer Service for Return Material Authorization number. 
Please retain all shipping labels and documentation. 

5.2 Preparation For Use 

Before the DTC-10-1 Host Adapter can be used, initial setup may be 
required. Be sure the power requirements for the Host Adapter are met 
(section 4.0). The host adapter is installed in a vacant slot in the 
S-100 backplane. 

A 50-pin, mass- terminated cable connects the host adapter to location 
J6 on the DTC controller board (pin 1 is marked on the host adapter 
connector as a triangle or dot and on the controller silkscreen) . Refer 
to the interconnection diagram in the appropriate controller 
specification for connection of the controller to the disk drives. Note 
that all cables, including drive cables, are of the mass-terminated 
type, so no inadvertant signal swapping can occur. 

Be sure the controller has adequate DC power (refer to the controller 
specification? the controller maintains the same power connector 
pinouts as the disk drive). To set up the controller, refer to the 
switch setting instructions found in the controller specification. 

The following sections describe in detail the proper jumper settings on 
the host adapter. 
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5.2.1 Address Switches 

The address switches are located in positions 12D and 7D. 

Note: If the switch is on, the logic compares for zero (OV to 0.8V ) on 
the S-100 bus. Bit assignment is as follows: 



12D Position 

1 
2 
3 
4 
5 
6 
7 

a 

7D Position 

1 
2 

3 
4 

5 
6 

7 
8 



Address Label 



A15 


F 


A14 


E 


A13 


D 


A12 


C 


All 


B 


A10 


A 


A9 


9 


A8 


8 


Address 


Label 


BOOT A9 


U 


BOOT A10 


T 


A7 


7 


A6 


6 


A5 


5 


A4 


4 


A3 


3 


A2 


2 



5.2.2 DMA Priority Switch 

The DMA priority is set by an 8 pin DIP Switch below 4B. 
Position Function Label 

1 
2 
3 
4 

If an external vectored interrupt controller is being used the INT line 
may be jumpered to the vectored interrupt lines VIO through VI7 (4 to 
11) instead of pin 73. 



DMA 3 


3 


DMA2 


2 


DMA1 


1 


DMAO 
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5.2.3 Parity 

The DTC-10-1 generates odd parity with the standard parity jumper at 
TP1 (near 12A) . On outputs from the controller the odd parity is 
checked and the PERR bit is set if bad parity is found. 

5.2.4 Phantom EPROM 

The DTC-10-1 has a socket for a BOOT PROM (at 7A) that can be accessed 
in the Phantom mode. There is also a Phantom state generator circuit 
that is set by RESET* or POR* and reset by a read to b3 . If the 
Phantom feature is not wanted, jumpers TP3 and TP5 should be 
disconnected. If the Phantom state generator is to be on an another 
board, but the on board phantom PROM is to be read, then jumpers TP3 
should be disconnected and jumper TP5 sould be connected. The 2716 used 
as the BOOT PROM is switch-selectable by Dipswitch 5D, positions 1 and 
2, to determine which 512-byte segment (out of 2048 bytes) is to be 
read in the Phantom mode. 



5.2.5 Jumper Summary 

Jumper Postion Function 

TP1 12A Host Data Parity 

TP2 3B DMA Control 



TP3 



TP4 



13B 



9D 



Phantom Control 



Extend I/O Address 



TP5 



14D 



PROM Read 



Description 

Preset for odd parity 

c-h DMA will hold for 

duration of data transfer 

c-d DMA will drop after each 
cycle 

Connects on-board Phantom 
generator to S-100 bus 

c-ext enables extended I/O 
address to 16 bits; 
65,536 addresses 

c-gnd enables 8-bit I/O 
address range; 
256 addresses 

Enables PROM to be read in 
Phantom mode 
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5.3 Initial Checkout 

The initial verification of the disk subsystem can be done via an 
Appropriate monitor PROM, or through a debugging utility such as DDT 
under CP/M* . 

First, verify that all the interface registers are accessible through 
the correct addresses and that the registers can be read/ written with 
the ejected results. Install driver routines by reading Appendix A or 
the DTC S-100 Driver BIOS Diskette. Next, attempt to issue a few 
commands to the disk subsystem, again via the console. 

A recommended approach is to first issue a RECALIBRATE command. After 
verif^g that it executed correctly, issue a SEEK command to verify 
that the Logical Address calculation has been performed correctly. 
Then iss^a FORMAT DRIVE command; the recommended interleave for the 
S-ISo system running at 2MHz is 4. Finally, data transfer commands 
should S Issued to verify the data. All commands can be issued via the 
console programmer's interface. 
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6.0 REFERENCE DOCUMENTATION 

This section provides information regarding the documentation 
available for using the DTC-10-1 Host Adapter. 

6.1 DTC-Supplied Documentation 

6.1.1 DTC Controller Specifications 

Each controller that is manufactured by DTC is described by its own 
specification. Refer to the appropriate controller document when 
attempting to program the disk subsystem. 

6.1.2 DTC Software Manual 

This manual explains how to install CP/M onto your system using the 
DTC-1403D Controller and the DTC-10-1 Host Adapter. Also available is a 
DTCBIOS diskette. 

6.2 Other Documentation 

6.2.1 IEEE S-100 

a. IEEE 696.1 Standard Specifications for S-100 Bus Interface Devices. 

b. S-100 CPU/ System Manual - use the version appropriate for your 
system. 

6.2.2 Disk Drive Documentation 

Use the appropriate drive manufacturer's manual for your disk drive. 
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APPENDIX A COMMANDS /PROGRAMMING 

An I/O request to the DTC controller is performed by passinq a command 
descriptor block (CDB) to the controller. The first byte of a CDB is 
the command class and opcode. The remaininq bytes specify the drive 
loqical unit number (LUN) , block address, control bytes, and number of 
blocks to transfer. The controller performs an implied seek and verify 
when commanded to access a block. 

Due to the different types of commands each controller recoqnizes, the 
command format for the DTC-10-1 Host Adapter will only indicate the 
skeletal representation of the command. The reader is directed to 
section 4.0 of the appropriate DTC controller specification for more 
detailed command information. 



A.l Command Format 

A. 1.1 Commands Requirinq 6 Bytes 



! 7 


6 5 4 


3 2 


1 







Command 


Byte 











Command 


Byte 


1 








Command 


Byte 


2 








Command 


Byte 


3 








Command 


Byte 


4 








Command 


Byte 


5 






1 7 


6 5 4 


3 


7 


1 






xxxx 

XXXX + 1 

xxxx + •> 

XXXX + 3 

XXXX + 4 

XXXX + 5 



XXXX is the HEX address that is loaded into the CIOPB location 
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A. 1.2 Commmands Requiring 10 Bytes 



I 



7 6 5 4 


3 : 


? 1 


Command 


Byte 





Command 


Byte 


1 


Command 


Byte 


2 


Command 


Byte 


3 


Command 


Byte 


4 


Command 


Byte 


5 


Command 


Byte 


6 


Command 


Byte 


7 


Command 


Byte 


a 


Command 


Byte 


9 


7 6 5 4 


3 : 


2 1 



xxxx 

XXXX + 1 
XXXX + •> 
XXXX + 3 
XXXX + 4 
XXXX + 5 
XXXX + 6 
XXXX + 7 
XXXX + R 
XXXX + 9 



XXXX is the HEX address that is loaded into the CIOPB location 



A. 2 Request Syndrome Command 

The REQUEST SYNDROME Command returns 2 bytes of information. The data 
returned for the REQUEST SYNDROME Command is listed as follows: 



Data Byte 
Data Byte 1 



XXXX 
XXXX + 1 



XXXX is the HEX address that is loaded into the DMA location 
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A. 3 Drive and Controller Sense Information 

Upon execution of the REQUEST SENSE command, the controller returns 
four bytes of information in the following format. (Refer to Drive and 
Controller Sense in section 4.0 of the DTC controller specifications 
for a detailed interpretation of these bytes). 



7 


6 5 4 


3 2 1 







Data 


Byte 






Data 


Byte 1 






Data 


Byte 7 






Data 


Byte 3 





I xxxx 

I 

I XXXX + 1 

! XXXX + 2 

I XXXX + 3 



XXXX is the HEX address that is loaded into the DMA location 



Note: Data that is received from the controller as well as data that 
is sent to the controller will be transferred in the above 
order. 
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APPENDIX B 



HOST BUS PIN ASSIGNMENT 



The host I/O bus uses a 50-pin connector (AMP 2-87227-5 or equivalent) 
The unused pins are spares for future use. The pin assigments are as 
follows: 



Signal 

DATAO 
DATA1 
DATA2 
DATA3 
DATA4 
DATA5 
DATA6 
DATA7 

PARITY 



BUSY 

ACK 

RST 

MSG 

SEL 

C/D 

REQ 

I/O 



Pin 


Number 


2 




4 




6 




8 




10 




12 




14 




16 




18 




20 


1 


22 


1 


24 


! 


26 


Future 


28 


Usage 


30 


1 


32 


I 


34 


I 


36 




38 




40 




42 




44 




46 




48 




50 





Note: All signals are negative true and all odd pins are connected to 
ground. The signal lines are terminated with 220 ohms to 5V and 
330 ohms to ground. 
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APPENDIX C IEEE S-100 SYSTEM BUS SIGNAL DEFINITION 

IEEE S-lOO Bus 
Component Side Pins 



Pin 



Signal 



Description 



1 


+8 volts 


2 


+16 volts 


3 


XRDY 


4 


VII* 


5 


VII* 


6 


VI2* 


•7 


VI3* 


8 


VI4* 


9 


VI5* 


10 


VI6* 


11 


VI7* 


1? 


NMI* 


13 


PWRFAIL* 


14 


DMA3* 


15 


A18 


16 


A16 


17 


A17 


18 


SDSB* 



19 



CDSB* 



20 


GND 


21 


NDEF 


22 


ADSB* 


23 


DODSB* 


24 


Phi Clk 


25 


PSTVAL 


26 


PHLDA 


27 


RFU 


28 


RFU 


29 


A5 


30 


A4 


31 


A3 


32 


A15 



Logic power - unregulated, max < 11. 5v 
Aux power - unregulated, max < 21. 5v 
Act H, one of two bus ready signals 
Vectored interrupt line 0, active low, open 
collector; used with a vectored interrupt 
circuit to speed interrupt handling. 
See pin 4 



Non-maskable interrupt; active low, open 

collector. 
Power failure signal, active low 
DMA request; active low, open collector 
Extended address bit 18 
Extended address bit 16 
Extended address bit l 7 
Disable the 8 status signals; active low, 

open collector 
Disable the 5 control output signals; 

active low, open collector 
Extra ground 
Not defined 
Disable the address lines (first 16); 

active low, open collector 
Disable data output lines; active low, 

open collector 
Phase 1 master timing for the bus 
Status valid strobe; active low, at PSYNC 

time indicates that stable address and 

status are on the bus. 

Hold acknowledge signal, active high 

Reserved for future use 
■I n H ii 

Address bit 5 
Address bit 4 
Address bit 3 
Address bit 15 
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33 


A12 


34 


A9 


35 


DOl 


36 


DOO 


37 


A10 


38 


D04 


39 


DO 5 


40 


D06 


41 


DI2 


42 


DI3 


43 


DI7 


44 


SMI 


45 


SOUT 


46 


SIMP 


47 


SMEMR 



48 
49 
50 



SHLTA 
CLOCK 
GND 



Address bit 12 
Address bit 9 

Data out bit 1, bidirectional data 1 
Data out bit 0, bidirectional data 
Address bit nlO 

Data out bit 4, bidirectional data 4 
Data out bit 5, bidirectional data 5 
Data out bit 6, bidirectional data 6 
Data in bit 2, bidirectional data 10 
Data in bit 3, bidirectional data 11 
Data m bit 7, bidirectional data 15 
Status indicatinq machine code fetch 
Status indicating I/o output cycle 
Status indicating i/o input cycle 
Status indicating memory read - not an 

interrupt instruction fetch 
Status indicating halt instruction is 

being acknowledged 
A 2MHz clock - not required to be 

synchronous with other events 
Main ground 



S-100 Circuit Side Pins 





+8 volts 


5 2 


-16 volts 


53 


GND 


54 


Slave CLR* 


55 


DMA0* 


56 


DMA1* 


57 


DMA2* 


58 


SXTRQ* 


59 


A19 


60 


SIXTN* 


61 


A20 


62 


A21 


63 


A22 


64 


A23 


65 


NDEF 


66 


NDEF 


67 


PHANTOM* 



68 



MWRT 



See pin 1 

Negative aux power, unregulated, max <21.5v 
Extra ground 

Resets bus slaves, is active with POC 
DMA arbitration line, active low, 

open collector 
same as DMA0* 
same as DMA0* 
Status signal which requests that 16-bit 

slaves assert SIXTN* 
Extended address bit 19 
An active low siqnal asserted by 16-bit bus 

slaves in response to SXTRQ* 
Extended address bit 20 
Extended address bit 21 
Extended address bit 22 
Extended address bit 23 
Not defined 
same as above 
Creates an alternate bank of memory, 

usually after POR* or RESET* 
Status indicated memory write 
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69 


RFU 


70 


GND 


71 


RFU 


72 


RDY 


73 


INT* 


74 


HOLD* 


75 


RESET* 


76 


PSYNC 


77 


PR/W* 


78 


PDBIN 


79 


AO 


R0 


Al 


81 


A2 


8?. 


A6 


83 


A7 


84 


A8 


85 


A13 


86 


A14 


87 


All 


88 


DO 2 


89 


DO 3 


90 


D07 


91 


DI4 


92 


DI5 


93 


DI6 


94 


DI1 


95 


DIO 


96 


SINTA 


97 


SWO* 


98 


ERROR* 


99 


POC* 


100 


GND 



Extra qround 

Ready, indicates memory or I/O is ready; 

active high, open collector 
The primary interrupt request signal is 

low true, open collector. 
Request processor stop for DMA purposes; 

active low, open collector 
Master reset signal; active low, open 

collector 
Control signal indicating beginning of new 

bus cycle 
Read high, write low with data from CPU 

valid during low phase. 
Control signal requestinq input data 
Address bit 
Address bit 1 
Address bit 2 
Address bit 6 
Address bit 7 
Address bit 8 
Address bit 13 
Address bit 14 
Address bit 11 

Data out bit 2, bidirectional data 2 
Data out bit 3, bidirectional data 3 
Data out bit 7, bidirectional data 7 

bidirectional data 12 
bidirectional data 13 
bidirectional data 14 
bidirectional data 9 
bidirectional data 8 
Status indicating fetch of interrupt 

instruction 
Status indicatinq transfer of data from 
bus master to bus slave 
Status indicatinq error condition durinq 

the present bus cycle 
Power on clear, must remain low for 10ms 
Main qround 



Data in bit 4, 
Data in bit 5, 
Data in bit 6, 
Data in bit 1, 
Data in bit 0, 
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APPENDIX D SAMPLE PROGRAM FOR THE DTC-10-1 (PROGRAMMED I/O) 

The DTC-10-1 Host Adapter uses programmed I/O, taking advantage of the 
fact that the DTC controllers have a built-in sector buffer. The 
control lines of the host bus are available to the CPU through the Bus 
Status Register. Data and commmands are transmitted through the host 
bus by a simple handshake procedure as outlined in the DTC controller 
specifications . The types of commands available to the user are as 
follows: 

STATUS Sends drive status to host adapter 

TEST DRIVE READY 
REQUEST SENSE 
CHECK TRACK FORMAT 
REQUEST SYNDROME 



MOTION CONTROL Moves heads without R/W operation 



SEEK 
RECALIBRATE 



R/W 



Read Write Operations 



READ 

WRITE 

COPY 



FORMAT Formats drive or tracks with specified standard format 

FORMAT TRACK 
FORMAT BAD TRACK 
FORMAT DRIVE 



DIAGNOSTICS Runs controller microdiagnostics 

RAM DIAGNOSTIC 

WRITE ECC 

READ ID 

DRIVE DIAGNOSTIC 
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Flow Diagrams 

Status commands: 

GET CONTROLLER 
SEND COMMANDS to controller 
READ STATUS DATA 
COMPLETION STATUS 

Motion Control: 

GET CONTROLLER 

SEND COMMANDS to controller 

COMPLETION STATUS 



Write Sector (s): 

GET CONTROLLER 
SEND COMMANDS 
LOAD DATA 
COMPLETION STATUS 



Read Sector (s) : 

GET CONTROLLER 
SEND COMMANDS 
WAIT FOR REQ 
READ DATA 
COMPLETION STATUS 



Copy: 

GET CONTROLLER 
SEND COMMANDS 
COMPLETION STATUS 



Diaqnostics: 

GET CONTROLLER 
SEND COMMANDS 
COMPLETION STATUS 
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Sample program to READ DATA FROM CONTROLLER: 



READ: 
RDREQ : 



i 



LHLD DMA 
IN BSTAT 
MOV C,A 
ANI 80H 
JZ RDREQ 
MOV A,C 
ANI 10H 
JNZ CMPSTAT 
IN DATAIN 
MOV M,A 
INX H 
JMP RDREQ 



; load data pointer 

; input bus status 

; store for further checking 

yloolc for REQ 

relse loop 

; check for COM 

?if COM present must be completion status 

; input data from controller 

;raove data to pointer 

? increment pointer 
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APPENDIX E 



DMA PROGRAMMING 



DMA programming is actually simpler than the processor I/O scheme, 
because the driver routine does not have to know if the command is read 
or write. Before the data transfer the DMA is enabled (which resets the 
done bit) . Commands which do not involve data transfers should use the 
processor I/O routine since the DMA is never turned on. These are check 
drive ready, check track, seek, recalibrate (class 0), and class 1, and 
class 6 commands. 



GETCON is identical with Pl/O routine. 



DMACOM: 



DCOMREQ i 



DONE? 



MVI A, 3 
OUT BCON 
LDA DMA+2 
OUT DMAOUT 
LDA DMA+1 
OUT DMAOUT 
LDA DMA 
OUT DMAOUT 
MVI B,6 
LHLD CIOPB 
IN BSTAT 
MOV C,A 
ORA A 
JP DCOMREQ 
ANI 40H 
JZ CMPSTAT 
MOV A,M 
OUT DATAOUT 
INX H 
DCR B 

JNZ DCOMREQ 
IN BSTAT 
ANI 1 
JZ DONE? 



IN CSTAT 
MOV C,A 
RET 



; enable DMA channel 

;get most significant byte of address 

;sent it to DMA address register 



; least significant byte of address 

;set up byte count 
;set up command pointer 
; look at host bus 



;wait for REQ 

? see if input, output means illegal command 

; illegal, finish with PIO 

; output command byte 

;decrement byte pointer 

;do more bytes 

?now wait for DONE bit 

?the transfer is complete and the 
completion status is in the CSTAT 
Register. 
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Sample program to SEND DATA TO CONTROLLER (a WRITE operation): 






LHLD DMA 
DAREQ: IN BSTAT 
MOV C,A 
ANI 8 OH 
JZ DAREQ 
ANI 10H 
JNZ CMPSTAT 

MOV A,M 
OUT DATAOUT 
INX H 
JMP DAREQ 

CMPSTAT: IN DATAIN 
MOV C,A 

LREQ: IN BSTAT 
MOV B,A 
ANI ROH 
JZ LREQ 
IN DATAIN 
ORA A 

JNZ BADBYTE 
MOV A,C 
ORA A 

JNZ BADSTAT 
MOV A,B 
ANI 01H 
JNZ BADPAR 
XRA A 
RET 



load pointer to data (16 bit address) 

input fron bus status 

store 

set flags 

wait for REQ 

check for COM 

on receipt of command completion status is 

present 

move data into accumulator 

output to controller 

increment pointer 

go back for another byte 

input completion status 

place in C for futher use 

looking for last REQ 

save for checking 

check for REQ 

loop untill found 

input last byte 

see if last byte is non-zero 

if last byte is non zero 

now check completion status 

to see if it is zero 

if not zero 

Now check last bus status 

for parity error 

high is bad parity 

zero accumulator 

GREAT! everything is OK 



For information on how to decode errors generated, refer to the 
appropriate DTC controller specification. 
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PROGRAMMMING: 

BASE equals Base I/O Address 

DATAIN equals BASE 

DATAOUT equals BASE 

BCON equals BASE+1 ;Buss Control 

BSTAT equals BASE+2 ; Bus Status 

DMAOUT equals Base+3 ; DMA control bytes 

DMAIN equals BASE+3 ; DMA status information 

CIOPB ; Command Address 

DMA ; Data Address bits to 7 

DMA+1 ; DMA bits 8 to 15 

DMA+2 ; DMA bits 16 to 23 

PIO equ true ; Processor I/O data transfer 

DMAT equ not PIO ;DMA data transfer 



Sample program to GET CONTROLLER: 



GETCON : 



CBUSY: 



IN BSTAT 
ANI 08H 
JNZ GETCON 
MVI A,40H 
OUT BCON 
IN BSTAT 
ANI 08H 
JZ CBUSY 
MVI A,02H 
OUT BCON 
RET 



; input from status port 

rselect bit 3 (busy) 

rif busy wait in getcon loop 

?get ready to assert SEL and DATAO 

?to get attention of controller 

r input from bus status 

7 again look at BUSY 

;we have controller attention else loop 

;get ready to allow tfata enable 

?done 

r return from get controller routine 



Sample program to OUTPUT COMMANDS 



OUTCOM: 


LHLD CIOPB 


COMREQ : 


IN BSTAT 




MOV C,A 




ORA A 




JP COMREQ 




ANI 10H 




RZ 




MOV A,C 




ANI 40H 




RZ 




MOV A,M 




OUT DATAOUT 




INX H 




JMP COMREQ 



; load pointer to command queue 

; input from bus status 

; store in C 

;set flags 

;wait for REQ 

; check for command/ data 

; return when data is requested 

;also see if controller switched direction 

;if it wants to send data, return 

•move commands from queue to accumulator 

rwrite comands to controller 

? increment pointer 

; loop as long as commands are requested 
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